英文版:
,
html标签
其 中 { { 和 }} 之间为handlerbars的变量;
{ {title}}
{ {body}}
把数据放到自己定义的
<script>
标签中; 编译模版
使用
Handlebars.compile()
进行编译模版; var source =$("#entry-template").html();
var template = Handlebars.compile(source);
智能编译模版(在移动端也能运行哦么么哒)
生成html代码
通过上面的模版和数据混合编译后的结果:
var context = {title: "标题", body: "我是字符串!"}var html = template(context);
{ {title}}
{ {body}}
var template = Handlebars.compile(source); var context = {title: "标题", body: "我是字符串!"} //数据信息 var html =template(context); document.getElementById("div1").innerHTML= html;
//jQuery中 html(),插入到div1
---------------------------------------------
//模版的代码和JS的代码如防止HTML被转义的方法;
{ { }}和 { { {}}}和区别就是, 如果你不希望变量里面的字符串被转义就使用{ { { }}}对变量进行处理;//可能以因为body等是html标签,避免将变量误认为特殊关键字,需要{ { { }}}
Handlebars的
{ {expression}}
表达式会返回一个 HTML编码 HTML-escape
过的值。如果 不希望Handlebars来编码这些值,使用三个大括号即可: { { {
。 { {title}}
{ { {body}}}
数据如下:
{ title: "All aboutTags", body: "
This is a post about <p> tags
"}
Handlebars 不会再对
定义的Helper如下: Handlebars.SafeString
安全字符串进行编码。如果你写的 helper 用来生成 HTML,就经常需要返回一个 new Handlebars.SafeString(result)
。在这种情况下,你就需要手动的来编码参数了。 Handlebars.registerHelper('link', function(text, url) { text = Handlebars.Utils.escapeExpression(text); url = Handlebars.Utils.escapeExpression(url); var result =''+ text +''; //手动编码是指这句? return new Handlebars.SafeString(result); });
这样来编码传递进来的参数,并把返回的值标记为 安全,这样的话,即便不是哟给你“三个大括号”,Handlebars 就不会再次编码它了。
渲染以后的结果如下:
< < , little to
> >, greater to
All About <p> Tags
This is a post about <p> tags
//代码如下:
-------------------------------------------------------------Handlerbars的自定义表达式
块级表达式:#开头,/结尾。块级表达式允许你定义一个helpers,并使用一个不同于当前的上下文(context)来调用你模板的一部分。现在考虑下这种情况,你需要一个helper来生成一段 HTML 列表:
{ { #list people}} { {firstName}} { {lastName}}{ { /list}}
并使用下面的上下文(数据):
{ people: [ {firstName: "Yehuda", lastName: "Katz"}, {firstName: "Carl", lastName: "Lerche"}, {firstName: "Alan", lastName: "Johnson"} ]}
此时需要创建一个 名为
list
的 helper 来生成这段 HTML 列表。这个 helper 使用 people
作为第一个参数,还有一个 options
对象(hash哈希)作为第二个参数。这个 options 对象有一个叫 fn
的属性,你可以传递一个上下文给它(fn),就跟执行一个普通的 Handlebars 模板一样: 在JS里面定义这个helper;
Handlebars.registerHelper('list', function(items, options) { var out ="
- "; for(var i=0, l=items.length; i
执行以后的结果是:
- Yehuda Katz
- Carl Lerche
- Alan Johnson
自定义块表达式还有很多别的特性, 比如可以直接使用 IF 和 ELSE;
//代码如下:
people
对应数据中的people[] }} { { #list people}} { {firstName}} { {lastName}} { { /list}}
块级的 helpers 还有很多其他的特性,比如可以创建一个 else
区块(例如,内置的 if helper 就是用 else)。注意,因为在你执行 options.fn(context)
的时候,这个 helper 已经把内容编码一次了,所以 Handlebars 不会再对这个 helper 输出的值进行编码了。如果编码了,这些内容就会被编码两 次!
Handlebars次级数据的渲染(Handlebars 路径)
Handlebars支持简单的下级对象获取和上级对象获取, 跟 Mustache一样样的.
{
{name}}
Handlebars 同样也支持嵌套的路径,这样的话就可以 在当前的上下文中查找内部嵌套的属性了。
{ {title}}
By { {author.name}}
{ {body}}
上面的模板使用下面这段上下文:
这样一来 Handlebars 就可以直接把JSON数据拿来用了。 var context = { title: "My First Blog Post!", author: { id: 47, name:"Yehuda Katz"}, body: "My first post. Wheeeee!"};
-------------------------
Handlebars 可以迭代Object对象(纯对象或者数组); 在模版中的 ../是对象的父级 ;
Comments
尽管 a 链接在输出时是以 comment 评论为上下文的,但它仍然可以退回上一层的上下文(post上下文)并取出permalink(固定链接)值。
var context = { post: { body:'这是文章内容', permalink: 'http://xx.com/xx', comments:[{ title:'这篇文章不错,赞一个' },{ title:'好文要顶!' }] }}
../
标识符表示对模板的父级作用域的引用,并不表示在上下文数据中的上一层。这是因为块级 helpers 可以以任何上下文来调用一个块级表达式,所以这个【上一层】的概念用来指模板作用域的父级更有意义些。 The exact value that
../
will resolve to varies based on the helper that is calling the block. Using ../
is only necessary when context changes, so children of helpers such as each
would require the use of ../
while children of helpers such as if
do not. { {permalink}}{ {#each comments}} { {../permalink}} { {#if title}} { {../permalink}} { {/if}}{ {/each}}In this example all of the above reference the same
permalink
value even though they are located within different blocks. This behavior is new as of Handlebars 4, the discuss the prior behavior as well as the migration plan. Handlebars也允许通过一个
this
的引用来解决 helpers 和 数据字段间的名字冲突: 下面展示的name都是同样的东西;
{
{./name}} or { {this/name}} or { {this.name}}
上面的这一种方式都会将 name
字段引用到当前上下文上,而不是 helper 上的同名属性。
-----------------------------------------------------
注释: { {!-- --}}
或者{ {! }}
或者 <!-- -->.
可以把模版专用的注释写在模版文件里面么么哒. 提高代码的可读性, 这个也算是最佳实践吧;
{ {!-- only output this author names if an author exists --}}{ {#if author}} { {firstName}}{ {lastName}}
{ {/if}}
{ {!-- --}}和{ {! }}的注释不会出现在生成的代码中; 如果使用 <!-- --> 注释的代码会出现在生成的代码中;
------------------------------------------------------
自定义标签(Helpers)
Handlebars 的 helpers 在模板中可以访问任何的上下文。可以通过
Handlebars.registerHelper
方法注册一个 helper。 { {/each}}By { {fullName author}}
{ {body}}Comments
{ {#each comments}}< h2>By { {fullName author}}{ {body}}
用下面的上下文数据和 helpers:
var context = { author: {firstName: "Alan", lastName: "Johnson"}, body: "I Love Handlebars", comments: [{ author: {firstName: "Yehuda", lastName: "Katz"}, body: "Me too!" }]};//就是下面这个helper提供了模版中的自定义标签;Handlebars.registerHelper('fullName', function(person) { return person.firstName +""+ person.lastName;});
生成的结果如下:
代码如下:By Alan Johnson
I Love Handlebars Comments
By Yehuda Katz
Me Too!
-----------------------------------------
Helpers 会把当前的上下文作为函数中的
this
上下文。 在自定义标签的Helper可以使用this, this是当前的对象;
- { {#each items}}
- { {agree_button}} { {/each}}
这个是填充的数据和定义的Helpers:(使用下面的 this上下文 和 helpers)
var context = { items: [ {name: "Handlebars", emotion: "love"}, {name: "Mustache", emotion: "enjoy"}, {name: "Ember", emotion: "want to learn"} ]};Handlebars.registerHelper('agree_button', function() { var emotion = Handlebars.escapeExpression(this.emotion), name = Handlebars.escapeExpression(this.name); return new Handlebars.SafeString( "" );});
生成的结果如下:
自定义标签(Helpers)的更多信息;
Handlebars 提供 if 在模版中进行简单的逻辑处理; 以及迭代处理的标签 each .
//例子代码段: //handlebars的IF ELSE语句和 each语句的例子:
内置的 Helpers
1.each
helper
你可以使用内置的 each
helper 来循环一个列表,循环中可以使用this
来代表当前被循环的列表项。
- { { #each people}}
- { { this}} { { /each}}
使用这个上下文:
{ people: [ "Yehuda Katz", "Alan Johnson", "Charles Jolley" ]}
会得到:
Yehuda Katz Alan Johnson Charles Jolley
事实上,可以使用 this
表达式在任何上下文中表示对当前的上下文的引用。还可以选择性的使用 else
,当被循环的是一个空列表的时候会显示其中的内容。
this
表达式在任何上下文中表示对当前的上下文的引用。还可以选择性的使用 else
,当被循环的是一个空列表的时候会显示其中的内容。{ {#each paragraphs}}{
{this}}{ {else}}No content
{ {/each}}
在使用 each
来循环列表的时候,可以使用 { {
@index
}}
来表示当前循环的索引值。
each
来循环列表的时候,可以使用 { {
@index
}}
来表示当前循环的索引值。{ {#each array}} { {@index}}: { {this}}{ {/each}}
对于 object 类型的循环,可以使用 { {@key}}
来表示:
{ {@key}}
来表示:{ { #each object}} { { @key}}: { { this}}{ {/each}}
--------------------------------------
2. with
helper
一般情况下,Handlebars 模板在计算值时,会把传递给模板的参数作为上下文。
var source = "{
{lastName}}, { {firstName}}";var template = Handlebars.compile(source);template({firstName: "Alan", lastName: "Johnson"});
结果如下:
不过也可以在模板的某个区域切换上下文,使用内置的Johnson, Alan
with
helper即可。 { {title}}
{ {#with author}}By { {firstName}} { {lastName}}
{ {/with}}
在使用下面数据作为上下文时:
{ title:"My first post!", author: { firstName: "Charles", lastName: "Jolley"}}
会得到如下结果:
----------------------------My first post!
By Charles Jolley
3. if
helper
if
表达式可以选择性的渲染一些区块。如果它的参数返回 false
,undefined
, null
, ""
或 []
(译注:还有 0
)(都是JS中的“假”值),Handlebars 就不会渲染这一块内容:
{ {#if author}}{ {firstName}} { {lastName}}
{ {/if}}
当时用一个空对象({}
)作为上下文时,会得到:
在使用
if
表达式的时候,可以配合 { {else}}
来使用,这样当参数返回 假 值时,可以渲染 else 区块: { { #if author}}{ {firstName}} { {lastName}}
{ { else}}Unknown Author
{ { /if}}
4.
unless
helper
unless
helper 和 if
helper 是正好相反的,当表达式返回假值时就会渲染其内容:
如果在当前上下文中查找{ {#unless license}}WARNING: This entry does not have a license!
{ {/unless}}
license
返回假值,Handlebars 就会渲染这段警告信息。反之,就什么也不输出。 5.log
helper
log
helper 可以在执行模板的时候输出当前上下文的状态。
{ {log"Look at me!"}}这样会把委托信息发送给
Handlebars.logger.log
,而且这个函数可以重写来实现自定义的log。
Literals
Helper calls may also have literal values passed to them either as parameter arguments or hash arguments. Supported literals include numbers, strings,
true
, false
, null
and undefined
. { {agree_button "My Text"class="my-class" visible=true counter=4}}
Partials
Handlebars partials allow for code reuse by creating shared templates. Rendering this template
{ {> userMessage tagName="h1" }} Comments
{ {#each comments}}{ {> userMessage tagName="h2" }}{ {/each}}
when using this partial and context:
Handlebars.registerPartial('userMessage', '<{ {tagName}}>By { {author.firstName}} { {author.lastName}} '+'{ {body}}');
var context = { author: {firstName: "Alan", lastName: "Johnson"}, body: "I Love Handlebars", comments: [{ author: {firstName: "Yehuda", lastName: "Katz"}, body: "Me too!" }]};
results in:
By Alan Johnson
I Love Handlebars Comments
By Yehuda Katz
Me Too!
Built-In Helpers
Handlebars offers a variety of built-in helpers such as the
if
conditional and each
iterator. API Reference
Handlebars offers a variety of APIs and utility methods for applications and helpers.
{ {title}}